我一直在寻找类似Python的while/else结构的东西来改进我的代码。这意味着循环被执行,如果循环中的条件在任何时候都不为真,那么它返回else语句中的值。在ruby中,我可以这样做:if@items.empty?"Empty"else@items.eachdo|item|itemendend那么有什么办法可以改善吗?提前谢谢你。 最佳答案 请记住,迭代器block会返回您放入其中的内容,可以对其进行测试以供进一步使用。ifarr.eachdo|item|item.some_action(some_arg)end.empty?
我需要解析一个文件以获取单独的SQL语句并从RailsController运行它们。我有以下代码:@sql_file="#{RAILS_ROOT}/lib/evidence_interface_import.sql"@sql_stmts_array=File.read(@sql_file).split(";")@sql_stmts_array.each_with_indexdo|sql_stmt,s_index|ActiveRecord::Base.connection.execute(sql_stmt)end拆分删除了“;”从SQL的末尾开始。有没有办法不删除“;”并且仍然使用“;”
有没有一种简单的方法可以测试多个变量在ruby中具有相同的值?一些链接:ifa==b==c==d#doesnotwork#Dosomethingbecausea,b,canddhavethesamevalueend当然可以根据主控检查每个变量以查看它们是否全部为真,但这是更多的语法并且不是那么清楚。ifa==b&&a==c&&a==d#doeswork#wehavenowtestedthesamething,butwithmoresyntax.end您需要这样的东西的另一个原因是,如果您在测试之前确实对每个变量进行了处理。ifarray1.sort==array2.sort==ar
我的代码是a={"1"=>"adi","2"=>"amar","3"=>"rave","4"=>"sum"}arr=["1","5","3"]如果散列中存在数组值,我想像这样提取所有值result=["adi","rave"]不使用任何循环。是否可能 最佳答案 你可以这样做:a.values_at(*arr).compact#=>["adi","rave"] 关于ruby-以非常有效的方式从哈希中获取多个值,我们在StackOverflow上找到一个类似的问题:
我需要做如下的事情e=[]m=[]p=[]t=[]...andsoonforabout10differentarrays有没有办法在一行中创建所有这些数组? 最佳答案 您可以使用以下方法来做到这一点:e,m,p,t...=Array.new(10){[]}事实证明[[]]*10不是正确的方法,[[]]*10用于重复,只是将同一个对象[]重复10次,所以所有变量最终会被分配给同一个对象。 关于ruby-在一行中创建多个数组,我们在StackOverflow上找到一个类似的问题:
我有一个包含新行的列表,我想将它转换成一个数组,例如JANFEBMARAPRMAY进入["JAN","FEB","MAR","APR","MAY]任何帮助将不胜感激。谢谢这样的东西似乎不起作用(text_file.txt包含上面的月份列表)file=File.new("text_file.txt","r")while(line=file.gets)line.chomplist=line.split(/\n/)puts"#{list}"end 最佳答案 这适用于1.9..不确定是否为空?虽然在1.8中可用%(JANFEBMARAPRM
是否有国家和城市gem,用户可以在其中选择国家并根据所选国家选择城市?我有多种解决方案,但它们都支持州而不是城市gem'country_select'gem'countries'gem'carmen-rails'我想要下拉列表中所有国家的列表,当我选择任何国家时,该国家/地区的所有城市都会出现在城市下拉列表中。这可以通过任何gem实现吗? 最佳答案 使用恰当命名的city-stategem.正如README所见,您可以:CS.cities(state,country)如果您想要给定国家/地区的所有城市,而不考虑州,您可以这样做:CS
给定任何有效的HTTP/HTTPS字符串,我想解析/转换它,以便最终结果恰好是字符串的根。因此给出的URL:http://foo.example.com:8080/whatsit/foo.bar?x=yhttps://example.net/我想要结果:http://foo.example.com:8080/https://example.net/我找到了documentation对于URI::Parser不是super平易近人。我最初的天真解决方案是一个简单的正则表达式,例如:/\A(https?:\/\/[^\/]+\/)/(即:匹配协议(protocol)后的第一个斜杠。)欢迎提
如何从字符串中删除空行?我努力了some_string=some_string.gsub(/^$/,"");还有更多,但没有任何效果。 最佳答案 删除空行:str.gsub/^$\n/,''注意:与其他一些解决方案不同,这个解决方案实际上删除了空行而不是换行符:)>>a="a\n\nb\n"=>"a\n\nb\n">>a.gsub/^$\n/,''=>"a\nb\n"解释:匹配一行的开始^和结束$,中间没有任何内容,后跟一个换行符。另一种更明确(虽然不太优雅)的解决方案:str.each_line.reject{|x|x.strip
我正在尝试创建一个页面来显示每个月的链接列表,按年分组。月份需要介于今天和第一个条目的日期这两个日期之间。我在一堵砖墙前,我不知道如何创建它。我们将不胜感激任何帮助问候亚当 最佳答案 只需将您想要的内容放入范围循环中,然后像这样使用Date::MONTHNAMES数组(date.year..laterdate.year).eachdo|y|mo_start=(date.year==y)?date.month:1mo_end=(laterdate.year==y)?laterdate.month:12(mo_start..mo_end